<?php
/**
 * common repository file Created by PhpStorm.
 * User: wumengmeng
 * Date: 2019/12/05
 * Time: 14:09
 */

namespace HiCommon\Repository;

use HiCommon\Model\MaintainShop;

class MaintainShopRepository extends BaseRepository
{
    public function base_model()
    {
        return new \HiCommon\Model\MaintainShop();
    }

    /**
     * 分页获取全部数据
     *
     * @param array $arr_option
     *
     * @return mixed
     * @author wumengmeng <wu_mengmeng@foxmail.com>
     */
    public function get_all($arr_option = [], $vehicle_model_id = 0)
    {
        return MaintainShop::whereHas('maintain_vehicle_model', function ($query) use ($vehicle_model_id) {
            if ($vehicle_model_id) { //根据车型车款筛选
                $query->where('vehicle_model_id', $vehicle_model_id);
            }
        })->commonget($arr_option);
    }

    /**
     * 分页获取数据
     *
     * @param array $arr_option
     *
     * @return mixed
     * @author wumengmeng <wu_mengmeng@foxmail.com>
     */
    public function get_list($arr_option = [])
    {
        return MaintainShop::commonpage($arr_option);
    }

    /**
     * 通过where分页获取数据
     *
     * @param array $arr_where
     * @param array $arr_option
     *
     * @return mixed
     * @author wumengmeng <wu_mengmeng@foxmail.com>
     */
    public function get_list_by_where($arr_where, $arr_option = [])
    {
        return MaintainShop::where($arr_where)->commonpage($arr_option);

    }

    /**
     * 根据条件统计数量
     *
     * @param array $arr_where
     *
     * @return mixed
     * @author wumengmeng <wu_mengmeng@foxmail.com>
     */
    public function get_count_by_where($arr_where)
    {
        return MaintainShop::where($arr_where)->count();
    }

    /**
     * 根据条件统计总和
     *
     * @param array $arr_where
     * @param string $s_field
     *
     * @return mixed
     * @author wumengmeng <wu_mengmeng@foxmail.com>
     */
    public function get_sum_by_where($arr_where = [], $s_field = 'mark')
    {
        return MaintainShop::where($arr_where)->sum($s_field);
    }

    /**
     * 根据条件批量删除信息
     *
     * @param array $arr_where
     * @param bool $method
     *
     * @return mixed
     * @author wumengmeng <wu_mengmeng@foxmail.com>
     */
    public function delete_by_where($arr_where = [], $method = false)
    {
        return MaintainShop::where($arr_where)->commondelete($method);
    }

    /**
     * 通过where获取一条数据
     *
     * @param array $arr_where
     * @param array $arr_option
     *
     * @return mixed
     * @author wumengmeng <wu_mengmeng@foxmail.com>
     */
    public function get_one_by_where($arr_where, $arr_option = [])
    {
        return MaintainShop::where($arr_where)->commonfirst($arr_option);
    }

    /**
     * 添加一条数据
     *
     * @param array $arr_input
     *
     * @return mixed
     * @author wumengmeng <wu_mengmeng@foxmail.com>
     */
    public function add_one($arr_input)
    {
        return MaintainShop::create($arr_input);
    }

    /**
     * 添加多条数据
     *
     * @param array $arr_data
     *
     * @return mixed
     * @author wumengmeng <wu_mengmeng@foxmail.com>
     */
    public function add_many($arr_data)
    {
        return MaintainShop::insert($arr_data);
    }

    /**
     * 查询一条数据
     *
     * @param int $n_id
     * @param array $arr_option
     *
     * @return mixed
     * @author wumengmeng <wu_mengmeng@foxmail.com>
     */
    public function get_one(int $n_id, $arr_option = [])
    {
        return MaintainShop::commonfind($n_id, $arr_option);
    }

    /**
     * 更新或新建一条数据
     *
     * @param $arr_where
     * @param $arr_input
     *
     * @return mixed
     * @author wumengmeng <wu_mengmeng@foxmail.com>
     */
    public function edit_or_create($arr_where, $arr_input)
    {
        $res = MaintainShop::where($arr_where)->first();
        if (is_null($res)) {
            MaintainShop::create(array_merge($arr_where, $arr_input));
        } else {
            MaintainShop::where($arr_where)->update($arr_input);
        }
        return MaintainShop::where($arr_where)->first();
    }

    /**
     * 修改一条数据
     *
     * @param array $arr_input
     *
     * @return mixed
     * @author wumengmeng <wu_mengmeng@foxmail.com>
     */
    public function edit_one(array $arr_input)
    {
        return MaintainShop::where('id', $arr_input['id'])->update($arr_input);
    }

    /**
     * 删除一条数据
     *
     * @param int $n_id
     *
     * @return mixed
     * @author wumengmeng <wu_mengmeng@foxmail.com>
     */
    public function delete_one(int $n_id)
    {
        return MaintainShop::where('id', $n_id)->commondelete();
    }

    /**
     * 修改一条数据状态
     *
     * @param int $n_id
     * @param int $n_state
     *
     * @return mixed
     * @author wumengmeng <wu_mengmeng@foxmail.com>
     */
    public function change_one_state(int $n_id, int $n_state)
    {
        return MaintainShop::where('id', $n_id)->update(['state' => $n_state]);

    }

    /**
     * 字段自增
     *
     * @param int $n_id
     * @param string $s_field
     * @param int $n_step
     *
     * @return mixed
     * @author wumengmeng <wu_mengmeng@foxmail.com>
     */
    public function increase_num($n_id, $s_field = 'commend_num', $n_step = 1)
    {
        return MaintainShop::where('id', $n_id)->increment($s_field, $n_step);
    }

    /**
     * 字段自减
     *
     * @param int $n_id
     * @param string $s_field
     * @param int $n_step
     *
     * @return mixed
     * @author wumengmeng <wu_mengmeng@foxmail.com>
     */
    public function decrease_num($n_id, $s_field = 'commend_num', $n_step = 1)
    {
        return MaintainShop::where('id', $n_id)->decrement($s_field, $n_step);
    }

    /**
     * 用户API接口用
     */
    public function by_where_limit(array $option ,$vehicle_model_id)
    {
        return MaintainShop::where($option['where'])
            ->whereHas('maintain_vehicle_model', function ($query) use ($vehicle_model_id) {
                if ($vehicle_model_id) { //根据车型车款筛选
                    $query->where('vehicle_model_id', $vehicle_model_id);
                }
            })
            ->with($option['with'])
            ->orderBy('updated_at', 'desc')
            ->limit($option['limit'])
            ->get($option['field'])
            ->toArray();
    }


    public function check_config($id)
    {
        return MaintainShop::where('maintain_config_pid', $id)->orWhere('maintain_config_id', $id)->count();
    }


}